<template>
  <el-dialog
    title="分配权限"
    :visible="dialogVisible"
    width="50%"
    @close="closeDialog"
    @open="openDialog">
    <!-- data：指定渲染的树形结构数据 -->
    <!-- show-checkbox：每个节点前加一个多选框 -->
    <!-- default-expand-all：默认展开所有的节点 -->
    <!-- node-key：为每个节点设置一个值 -->
    <!-- highlight-current：为当前被点击的节点设置高亮效果 -->
    <!-- props：为组件添加一些配置，可以修改组件默认读取的字段 -->
    <!-- check-strictly：是否取消父子关联：true表示取消，false表示不取消 -->
    <el-tree
      :data="list"
      show-checkbox
      default-expand-all
      node-key="id"
      ref="tree"
      highlight-current
      :props="defaultProps"
      check-strictly>
    </el-tree>
    <span slot="footer" class="dialog-footer">
      <el-button @click="$emit('close-dialog')">取 消</el-button>
      <el-button type="primary" @click="submit">确 定</el-button>
    </span>
  </el-dialog>
</template>

<script>
import { getPermissionList } from '@/api/permission'
import { recurTransTree } from '@/utils/transTree'
import { assignPermission, getRoleDetail } from '@/api/setting'

export default {
  props: {
    dialogVisible: {
      type: Boolean,
      required: true
    },
    roleId: {
      type: String,
      required: true
    }
  },
  data() {
    return {
      list: [],
      defaultProps: {
        label: 'name'
      }
    }
  },
  methods: {
    // 点击 X 和蒙板时，关闭弹窗
    closeDialog() {
      this.$emit('close-dialog')
    },
    // 弹窗打开
    async openDialog() {
      // 获取权限点列表数据
      const res = await getPermissionList()
      this.list = recurTransTree(res.data, '0')
      // 获取角色详情数据
      const roleDetail = await getRoleDetail(this.roleId)
      // roleDetail.data.permIds 角色已经被分配的权限数据组成的数组
      // this.$refs.tree.setCheckedKeys：勾选被选中的节点
      this.$refs.tree.setCheckedKeys(roleDetail.data.permIds)
      // console.log(roleDetail.data.permIds);
    },
    // 点击确定
    async submit() {
      // console.log(this.$refs.tree.getCheckedKeys());
      // this.$refs.tree.getCheckedKeys(): 被勾选的节点的key值组成的数组
      // 发起请求
      await assignPermission({
        id: this.roleId,
        permIds: this.$refs.tree.getCheckedKeys()
      })
      // 提示用户
      this.$message.success('分配权限点成功')
      // 关闭弹窗
      this.$emit('close-dialog')
    }
  }
}
</script>

<style>

</style>